Completed
Push — master ( 0083cf...5b9113 )
by Elbert
41s
created

inject.js ➔ ???   B

Complexity

Conditions 2
Paths 2

Size

Total Lines 61

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
nc 2
nop 0
dl 0
loc 61
rs 8.2763
c 1
b 0
f 0

1 Function

Rating   Name   Duplication   Size   Complexity  
C inject.js ➔ ... ➔ ??? 0 33 9

How to fix   Long Method   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
(() => {
2
	try {
3
    addEventListener('message', onMessage);
0 ignored issues
show
Bug introduced by
The local (let) variable onMessage is used before it is defined. This will cause a reference error.
Loading history...
4
5
    const onMessage = event => {
6
      if ( event.data.id !== 'patterns' ) {
7
        return;
8
      }
9
10
      removeEventListener('message', onMessage);
11
12
      const patterns = event.data.patterns || {};
13
14
      const js = {};
15
16
      for ( let appName in patterns ) {
17
        if ( patterns.hasOwnProperty(appName) ) {
18
          js[appName] = {};
19
20
          for ( let chain in patterns[appName] ) {
21
            if ( patterns[appName].hasOwnProperty(chain) ) {
22
              js[appName][chain] = {};
23
24
              for ( let index in patterns[appName][chain] ) {
25
                const value = detectJs(chain);
26
27
                if ( value && patterns[appName][chain].hasOwnProperty(index) ) {
28
                  js[appName][chain][index] = value;
29
                }
30
              }
31
            }
32
          }
33
        }
34
      }
35
36
      postMessage({ id: 'js', js }, '*');
37
    };
38
39
    const detectJs = chain => {
0 ignored issues
show
Unused Code introduced by
The constant detectJs seems to be never used. Consider removing it.
Loading history...
40
      const properties = chain.split('.');
41
42
      let value = properties.length ? window : null;
43
44
      for ( let i = 0; i < properties.length; i ++ ) {
45
        let property = properties[i];
46
47
        if ( value && value.hasOwnProperty(property) ) {
48
          value = value[property];
49
        } else {
50
          value = null;
51
52
          break;
53
        }
54
      }
55
56
      return typeof value === 'string' || typeof value === 'number' ? value : !!value;
57
    };
58
  } catch(e) {
59
    // Fail quietly
60
  }
61
})();
62